﻿<html DIR="LTR" xmlns:tool="http://www.microsoft.com/tooltip" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:ddue="http://ddue.schemas.microsoft.com/authoring/2003/5" xmlns:MSHelp="http://msdn.microsoft.com/mshelp">
  <head>
    <META HTTP-EQUIV="Content-Type" CONTENT="text/html; CHARSET=utf-8" />
    <META NAME="save" CONTENT="history" />
    <title>使用多个结果集</title>
    
    <link rel="stylesheet" type="text/css" href="../local/Classic.css">
      
    </link>
    
    <script src="../local/script.js">
      
    </script><script src="../local/script_main.js">&amp;nbsp;</script>
  </head>
  <body>
    <!--Topic built:04/01/2010 05:03:28-->

    
    
    
    
    
    
    
    
    
    <div id="header">
      <table width="100%" id="topTable"><tr>
          <td align="left">
            <span id="headerBold">使用多个结果集</span>
          </td>
          <td align="right">
            
          </td>
        </tr></table>
      
      
      
    </div>
    <div id="mainSection">
      
        
        
    <font color="DarkGray">
      
    </font>
    <p />
    
    <p />
  
        <div id="introductionSection" class="section">
    <p>使用返回多个结果集的内联 SQL 或 SQL Server 存储过程时，Microsoft SQL Server JDBC Driver 提供 <a href="ec24963c-8b51-4838-91e9-1fbfa2347451.htm">SQLServerStatement</a> 类的 <a href="929a14e2-8e98-4c32-89aa-86733c717ec1.htm">getResultSet</a> 方法，以检索返回的每个数据集。此外，当运行返回多个结果集的语句时，可以使用 <b>SQLServerStatement</b> 类的 <a href="e1367f39-23d7-4e26-b160-6d988d7e6988.htm">execute</a> 方法，因为它将返回一个 <b>boolean</b> 值，该值指示返回的值是结果集还是更新计数。</p>
    <p>如果 <b>execute</b> 方法返回 <b>true</b>，则运行的语句已返回了一个或多个结果集。通过调用 <b>getResultSet</b> 方法可以访问第一个结果集。若要确定是否提供了多个结果集，可以调用 <a href="6b18510a-4d6d-4eeb-a9d0-32e920eb0048.htm">getMoreResults</a> 方法，如果提供了多个结果集，则该方法返回 <b>boolean</b> 值 <b>true</b>。如果有多个结果集可用，则可以再次调用 <b>getResultSet</b> 方法进行访问，继续使用这个过程直到所有的结果集都得到处理。如果 <b>getMoreResults</b> 方法返回 <b>false</b>，则没有多个结果集要处理。</p>
    <p>如果 <b>execute</b> 方法返回 <b>false</b>，则所运行的语句返回了更新计数值，可以通过调用 <a href="e9570228-4500-44b6-b2f1-84ac050b5112.htm">getUpdateCount</a> 方法检索此值。</p>
    <div style="margin: .5em 1.5em .5em 1.5em"><b>注意：</b>
      有关更新计数的详细信息，请参阅<a href="64cf4877-5995-4bfc-8865-b7618a5c8d01.htm">使用带有更新计数的存储过程</a>。<p />
    </div>
    <p>在下面的实例中，将向此函数传递 SQL Server 2005 AdventureWorks 示例数据库的打开连接，并构造一条 SQL 语句，该语句在运行后将返回两个结果集：</p>
    <div class="sampleCode"><span codeLanguage="other"><pre>public static void executeStatement(Connection con) {
   try {
      String SQL = "SELECT TOP 10 * FROM Person.Contact; " +
                   "SELECT TOP 20 * FROM Person.Contact";
      Statement stmt = con.createStatement();
      boolean results = stmt.execute(SQL);
      int rsCount = 0;

      //Loop through the available result sets.
     do {
        if(results) {
           ResultSet rs = stmt.getResultSet();
           rsCount++;

           //Show data from the result set.
           System.out.println("RESULT SET #" + rsCount);
           while (rs.next()) {
              System.out.println(rs.getString("LastName") + ", " + rs.getString("FirstName"));
           }
           rs.close();
        }
        System.out.println();
        results = stmt.getMoreResults();
        } while(results);
      stmt.close();
      }
   catch (Exception e) {
      e.printStackTrace();
   }
}
</pre></span></div>
    <p>在这种情况下，返回的结果集的数目为 2。但是，如此编写代码是为了在返回了未知数目的结果集时，例如在调用存储过程时，这些结果集也会全部得到处理。若要查看调用返回多个结果集和更新计数的存储过程的实例，请参阅<a href="6b807a45-a8b5-4b1c-8b7b-d8175c710ce0.htm">处理复杂语句</a>。</p>
    <div style="margin: .5em 1.5em .5em 1.5em"><b>注意：</b>
      调用 <b>SQLServerStatement</b> 类的 <b>getMoreResults</b> 方法时，会隐式关闭以前返回的结果集。<p />
    </div>
  </div><span id="seeAlsoSpan"><h1 class="heading">请参阅</h1></span><div id="seeAlsoSection" class="section" name="collapseableSection"><a href="7f8f3e8f-841e-4449-9154-b5366870121f.htm">通过 JDBC 驱动程序使用语句</a><br /><br /></div><!--[if gte IE 5]>
			<tool:tip element="seeAlsoToolTip" avoidmouse="false"/><tool:tip element="languageFilterToolTip" avoidmouse="false"/><tool:tip element="roleInfoSpan" avoidmouse="false"/>
		<![endif]-->
      <div id="footer" class="section">
        
		<hr />
		
		<span id="fb" class="feedbackcss">
			
			
		</span>
		
		<a href="9bad553b-9e70-4696-8499-2e35f772a1e0.htm">
			
			© 2010 Microsoft Corporation。保留所有权利。
		</a>
 	
	
      </div>
    </div>
  </body>
</html>